<template>
  <div class="update-birthday">
    <van-datetime-picker
      v-model="currentDate"
      type="date"
      :min-date="minDate"
      :max-date="maxDate"
      @cancel="$emit('close')"
      @confirm="onConfirm"
    />
  </div>
</template>

<script>
import { updateUserProfile } from '@/api/user';
import dayjs from 'dayjs';
export default {
  name: 'updateBirthday',
  data() {
    return {
      minDate: new Date(1970, 0, 1),
      maxDate: new Date(),
      currentDate: new Date(this.value)
    };
  },
  props: {
    value: {
      type: String,
      required: true
    }
  },
  methods: {
    async onConfirm() {
      this.$toast.loading({
        message: '保存中',
        duration: 0, // 持续展示
        forbidClick: true // 禁止背景点击
      });
      try {
        const currentDate = dayjs(this.currentDate).format('YYYY-MM-DD');
        await updateUserProfile({
          birthday: currentDate
        });
        this.$emit('input', currentDate);
        this.$emit('close');
        this.$toast.success('更改成功');
      } catch (err) {
        this.$toast.fail('更新失败');
      }
    }
  }
};
</script>

<style></style>
